#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
typedef long long ll;
int n;
ll dp[10005];
void solve()
{
	memset(dp,0,sizeof(dp));
	dp[0]=1ll;
	for(ll i=1ll;i*i*i<=n;i++)
	{
		for(ll j=0ll;j<=n;j++)
		{
			if(j>=i*i*i)
			{
				dp[j]+=dp[j-i*i*i];
			}
		}
	}
}
int main()
{
	while(cin>>n)
	{
		solve();
		cout<<dp[n]<<endl;
	}
	return 0;
}